CLAIMS 



What is claimed is: 

A method for selectively releasing locks on data, comprising the steps of: 
(i) providing at least one savepoint in a transaction, wherein at least one lock is 
assigned tp the at least one savepoint and at least one lock is assigned to the transaction; 

(b) \ rolling back the transaction to the at least one savepoint; and 

(c) 1 releasing the at least one lock assigned to the at least one savepoint, wherein 

the at least one lock assigned to the transaction is maintained. 

1 1 

2. \ The method of claim 1, wherein the providing step (a) comprises: 

(al) 1 providing a sequence of savepoints in the transaction, wherein at least one 
lock is assigned} to each of the savepoints and the at least one lock is assigned to the 
transaction. 

3. The method of claim 1, wherein the rolling step (b) comprises: 
(bl) rolling back the transaction to one of a sequence of savepoints. 

4. The method of claim 1, wherein the releasing step (c) comprises: 

(cl) releasin^t least one lock assigned to one of a sequence of savepoints to 
which the transaction is rolled back; and 

(c2) releasing atVeast one lock assigned to subsequent savepoints, wherein the at 
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5 least one Iock assigned to the transaction and at least one lock assigned to preceding 

6 savepoints arAmaintained. 

1 5. TWe method of claim 4, further comprising: 

2 (c3) releasing another of the sequence of savepoints. 

1 6. The method of claim 5, further comprising: 

2 (c4) reassigning^ least one lock assigned to the another of the sequence of 

3 savepoints to a preceding sa\epoint. 

\ 

1=5 \ 

O 1 7. The method of clarm 5, further comprising: 

— 2 (c4) maintaining knowledge of the released another of the sequence of savepoints, 

p 3 such that if the transaction is rolled back to a preceding savepoint, the at least one lock 

r= i \ 

rfl 4 assigned to the released another of the sequence of savepoints is released. 

1 8. A method for selectively releasing locks on data, comprising the steps of: 

2 (a) providing a sequence of savenoints in a transaction, wherein at least one lock 

3 is assigned to each of the savepoints and at leaVt one lock is assigned to the transaction; 

4 (b) rolling back the transaction to oneyof the sequence of savepoints; 

5 (c) releasing the at least one lock assigned to the one of the sequence of 

6 savepoints; and \ 

7 (d) releasing the at least one lock assigned to\ubsequent savepoints, wherein the 
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8 at least onelo :k assigned to the transaction and the at least one lock assigned to preceding 

9 savepoints are maintained. 



2 
3 
4 
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9. h computer readable medium with program instructions for selectively 
releasing locks hn data, comprising the instructions for: 

(a) providing at least one savepoint in a transaction, wherein at least one lock is 
assigned to the at le\st one savepoint and at least one lock is assigned to the transaction; 

(b) rollingpack the transaction to the at least one savepoint; and 

(c) releasinAthe at least one lock assigned to the at least one savepoint, wherein 
the at least one lock assigned to the transaction is maintained. 



L 1 

m 2 

fy 
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10. The medium of\plaim 9, wherein the providing instruction (a) comprises 
instructions for: 

(al) providing a sequence of savepoints in the transaction, wherein at least one 
lock is assigned to each of the savepoVts and the at least one lock is assigned to the 
transaction. 



1 

2 
3 



1 1 . The medium of claim 9, wherein the rolling instruction (b) comprises 



instructions for: 



(bl) rolling back the transaction to one of a sequence of savepoints. 



12. The medium of claim 9, wherein the releasing instruction (c) comprises 
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instructions for: 



(cl) 



releasing at least one lock assigned to one of a sequence of savepoints to 
which the transaction is rolled back; and 

(c2) releasing at least one lock assigned to subsequent savepoints, wherein the at 
least one lock assigned to the transaction and at least one lock assigned to preceding 
savepoints are maintained. 



:-; 2 



1 3 . The mediumW claim 1 2, further comprising instructions for: 
(c3) releasing anothek of the sequence of savepoints. 



u l 
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14. The medium of clainiyl 3, further comprising instructions for: 
(c4) reassigning at least one\ock assigned to the another of the sequence of 
savepoints to a preceding savepoint. 



1 

2 
3 
4 



15. The medium of claim 1 3, further comprising instructions for: 
(c4) maintaining knowledge of the released another of the sequence of savepoints, 
such that if the transaction is rolled back to a preceding savepoint, the at least one lock 
assigned to the released another of the sequence of savepoints is released. 



1 
2 
3 



1 6. A computer readable medium with prog^m instructions for selectively 
releasing locks on data, comprising the instructions for: 

(a) providing a sequence of savepoints in a transition, wherein at least one lock 
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4 is assigned to each of the savepoints and at least one lock is assigned to the transaction; 

5 (b) \ rolling back the transaction to one of the sequence of savepoints; 

6 (c) releasing the at least one lock assigned to the one of the sequence of 

7 savepoints; and 

8 (d) releasing the at least one lock assigned to subsequent savepoints, wherein the 

9 at least one lock assigned to the transaction and the at least one lock assigned to preceding 
1 0 savepoints are maintained. 
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17. A systenx, comprising: 

a transaction, wherein at least one lock is assigned to the transaction; and 

\ 

at least one savepoint associated with the transaction, wherein at least one lock is 
assigned to the at least one savepoint, wherein in a rollback to the at least one savepoint, the 
at least one lock assigned to the at least one savepoint is released, wherein the at least one 
lock assigned to the transaction is maintained. 



1 18. A system, comprising 

2 a data manager for performing \asks on data, wherein the tasks comprise: 

3 providing at least one savbpoint in a transaction, 

4 assigning at least one lock to the at least one savepoint, 

5 assigning at least one lock to the transaction, 

6 responding to a recovery manager request for a rollback to the at least one 

7 savepoint by undoing operations performed sinceuhe at least one savepoint according to a 
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8 log, and \ 

9 \ requesting to a lock manager for release of the at least one lock assigned to 

10 the at least one savepoint; 

1 1 the lo&c manager for creating and maintaining the at least one lock assigned to the at 

12 least one savepdint and the at least one lock assigned to the transaction, and for releasing the 

1 3 at least one lock assigned to the at least one savepoint when the transaction is rolled back to 

14 the at least one savepoint; 

15 a log manage! for storing information on the tasks in the log, wherein the log 

2l6 comprises information concerning data and schema modifications, and the at least one 

I \ 

\Lll7 savepoint; and \ 

C?i g the recovery manager, wherein the recovery manager processes the request for the 

^19 rollback to the at least one savepoint by advising the data manager of the request. 
Q \ 



2021P/SVL920010002US1 



